博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
发布功能完成。
阅读量:7188 次
发布时间:2019-06-29

本文共 3996 字,大约阅读时间需要 13 分钟。

  • 编写要求登录的装饰器

from functools import wraps

def loginFirst(func): #参数是函数

@wraps(func)

      def wrapper(*args, ** kwargs): #定义个函数将其返回

          #要求登录

          return func(*args, ** kwargs)

      return wrapper #返回一个函数

  • 应用装饰器,要求在发布前进行登录,登录后可发布。
@app.route('/question/',methods=['GET','POST']) @loginFirst def question():

 

  • 建立发布内容的对象关系映射。
class Question(db.Model):
  • 完成发布函数。

保存到数据库。

重定向到首页。

question.html

{% extends'base.html' %}{% block title %}    发布问答{% endblock %}{% block head %}    
{% endblock %}{% block main %}

发布问答

{% endblock %}

py

from flask import Flask,render_template,request,redirect,url_for,sessionfrom flask_sqlalchemy import SQLAlchemyimport configfrom datetime import datetimefrom functools import wrapsapp = Flask(__name__)app.config.from_object(config)db=SQLAlchemy(app)class User(db.Model):    __table__name = 'user'    id = db.Column(db.Integer,primary_key=True,autoincrement=True)    username = db.Column(db.String(20),nullable=False)    password = db.Column(db.String(20),nullable=False)    nickname = db.Column(db.String(50))class Question(db.Model):    __tablename__ = 'question'    id = db.Column(db.Integer, primary_key=True, autoincrement=True)    title = db.Column(db.String(100), nullable=False)    detail = db.Column(db.Text, nullable=False)    creat_time = db.Column(db.DateTime, default=datetime.now)    author_id = db.Column(db.Integer, db.ForeignKey('user.id'))    author = db.relationship('User', backref=db.backref('question'))#db.create_all()@app.route('/')def index():    return render_template('index.html')@app.route('/zhuce/',methods=['GET','POST'])def zhuce():    if request.method =='GET':        return  render_template('zhuce.html')    else:        usern = request.form.get('name')        teln = request.form.get('password')        passw = request.form.get('password1')        user = User.query.filter(User.username==usern).first()        if user:            return 'username existed'        else:            user= User(username=usern,tel=teln,password=passw)            db.session.add(user)            db.session.commit()            return redirect(url_for('login'))@app.route('/login/', methods=['GET','POST'])def login():    if request.method == 'GET':        return render_template('login.html')    else:        username = request.form.get('username')        password = request.form.get('password')        user = User.query.filter(User.username == username).first()        if user:            if user.password ==password:                session['user'] = username                return redirect(url_for('index'))            else:                return u'password error'        else:            return u'username is not existed'@app.context_processordef mycontext():    usern = session.get('user')    if usern:        return{
'username':usern} else: return {}@app.route('/logout')def logout(): session.clear() return redirect(url_for('index'))def loginFirst(func): @wraps(func) def wrapper(*args,**kwargs): if session.get('user'): return func(*args,**kwargs) else: return redirect(url_for('login')) return wrapper@app.route('/question/',methods=['GET','POST'])@loginFirstdef question(): if request.method == 'GET': return render_template('question.html') else: title = request.form.get('title') detail = request.form.get('detail') author_id = User.query.filter(User.username == session.get('user')).first().id question = Question(title=title, detail=detail, author_id=author_id) db.session.add(question) db.session.commit() return redirect(url_for('index'))if __name__ == '__main__': app.run(debug=True)

 

转载于:https://www.cnblogs.com/gdlyzx/p/7911736.html

你可能感兴趣的文章
CSS3 pointer-events介绍 | CSS | 前端观察
查看>>
图论 List
查看>>
图的邻接表、拓扑排序、无权最短路径和加权最短路径
查看>>
C_数据结构_递归实现求阶乘
查看>>
(补充)9.Struts2中的OGNL表达式
查看>>
1572: [Usaco2009 Open]工作安排Job
查看>>
Django Rest Framework之版本控制
查看>>
网关协议学习:CGI、FastCGI、WSGI
查看>>
梯度下降算法以及其Python实现
查看>>
[bzoj 1355][Baltic2009]Radio Transmission
查看>>
Antialiasing with Transparency
查看>>
c# 类一般在哪里实例化,是在类内、方法内还是其他地方?
查看>>
自定义 checkbox、 radio 样式
查看>>
杭电2141--Can you find it?
查看>>
BOM DOM 简介
查看>>
[转载]Oracle修改表空间大小
查看>>
Oracle函数学习总结(1)
查看>>
javascript函数和内置对象
查看>>
Hadoop本地库
查看>>
Python中修改文件的核心思路
查看>>